# **Project 2: SPI Slave with Single Port RAM**

**Team name: No Moore Bugs** 

# **Team members:**

Yousef Wael Mahmoud Alkattan

Hayah Mahmoud

Robert moshref milad azmy

#### 1. Questasim Waveform

#### 1. reset



#### 2. write address test



#### 3. write data test



#### 4. read address test.



# 5. read data test



# 6. read address test 2 at the same location the write address command was executed



#### 7. read data test 2 at the same location the write address command was executed



### Transcript messages:

```
# WRITE ADDR: RAM[0x59] -> Expected Data: 0x58, Stored Data: 0x58
# WRITE DATA: RAM[0x59] -> Expected Data: 0x72, Stored Data: 0x72
# READ ADDR: Requested RAM[0x2e] -> Expected Data: 0x5A, Stored Data: 0x5a
# READ DATA: Data received from RAM[0x2e] -> Expected: 0x5A, Received: 0x5a
# READ ADDR: Requested RAM[0x59] -> Expected Data: 0x72, Stored Data: 0x72
# READ DATA: Data received from RAM[0x59] -> Expected: 0x72, Received: 0x72
```

#### 2. Vivado simulation:

# Implementation timing summary to select the best encoding:

#### 1. One-hot encoding



#### 2. Sequential encoding



## 3. Gray encoding



Best encoding for the design is **gray encoding** which has the highest negative setup slack, which is important for operating at the highest frequency.

# 1. Elaboration schematic











# 2. Synthesis





# Slave



| State     | New Encoding | Previous Encoding |
|-----------|--------------|-------------------|
| IDLE      | 000          | 00000             |
| CHK_CMD   | 001          | 00001             |
| WRITE     | 011          | 00011             |
| READ_ADD  | 010          | 00111             |
| READ_DATA | 111          | 00110             |

INFO: [Synth 8-3354] encoded FSM with state register 'cs\_reg' using encoding 'gray' in module 'SPI\_slave' WARNING: [Synth 8-327] inferring latch for variable 'FSM\_gray\_ns\_reg' [E:/project2/SPI\_slave.v:35]

Finished RTL Optimization Phase 2 : Time (s): cpu = 00:00:57 ; elapsed = 00:01:13 . Memory (MB): peak = 759.2

| Name              | Slice LUTs<br>(20800) | Slice Registers<br>(41600) | F7<br>Muxes<br>(16300) | Block RAM Tile<br>(50) | Bonded IOB<br>(106) | BUFGCTRL<br>(32) |
|-------------------|-----------------------|----------------------------|------------------------|------------------------|---------------------|------------------|
| ∨ N SPI           | 29                    | 33                         | 1                      | 0.5                    | 5                   | 1                |
| RAM (sp_RAM)      | 2                     | 9                          | 1                      | 0.5                    | 0                   | 0                |
| slave (SPI_slave) | 27                    | 24                         | 0                      | 0                      | 0                   | 0                |

# Critical path



| Setup                        |          | Hold                         |          | Pulse Width                              |          |
|------------------------------|----------|------------------------------|----------|------------------------------------------|----------|
| Worst Negative Slack (WNS):  | 6.261 ns | Worst Hold Slack (WHS):      | 0.142 ns | Worst Pulse Width Slack (WPWS):          | 4.500 ns |
| Total Negative Slack (TNS):  | 0.000 ns | Total Hold Slack (THS):      | 0.000 ns | Total Pulse Width Negative Slack (TPWS): | 0.000 ns |
| Number of Failing Endpoints: | 0        | Number of Failing Endpoints: | 0        | Number of Failing Endpoints:             | 0        |
| Total Number of Endpoints:   | 83       | Total Number of Endpoints:   | 83       | Total Number of Endpoints:               | 33       |

All user specified timing constraints are met.

# Synthesis after adding the debug core





# 3. Implementation

| Name              | , Slice LUT<br>(20800) | Slice Registers<br>(41600) | F7<br>Muxes<br>(16300) | Slice<br>(815<br>0) | LUT as Logic<br>(20800) | LUT Flip Flop Pairs<br>(20800) | Block RAM Tile<br>(50) | Bonded IOB<br>(106) | BUFGCTRL<br>(32) |
|-------------------|------------------------|----------------------------|------------------------|---------------------|-------------------------|--------------------------------|------------------------|---------------------|------------------|
| ∨ N SPI           | 3                      | 33                         | 1                      | 18                  | 30                      | 7                              | 0.5                    | 5                   | 1                |
| RAM (sp_RAM)      |                        | 3 9                        | 1                      | 3                   | 3                       | 0                              | 0.5                    | 0                   | 0                |
| slave (SPI_slave) | 2                      | 7 24                       | 0                      | 17                  | 27                      | 5                              | 0                      | 0                   | 0                |

| Setup                        |          | Hold                         |          | Pulse Width                              |          |
|------------------------------|----------|------------------------------|----------|------------------------------------------|----------|
| Worst Negative Slack (WNS):  | 6.208 ns | Worst Hold Slack (WHS):      | 0.045 ns | Worst Pulse Width Slack (WPWS):          | 4.500 ns |
| Total Negative Slack (TNS):  | 0.000 ns | Total Hold Slack (THS):      | 0.000 ns | Total Pulse Width Negative Slack (TPWS): | 0.000 ns |
| Number of Failing Endpoints: | 0        | Number of Failing Endpoints: | 0        | Number of Failing Endpoints:             | 0        |
| Total Number of Endpoints:   | 0.4      | Total Number of Endnoints:   | 0.4      | Total Number of Endpoints:               | 22       |





# Messages:

